home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 1997 January: Mac OS SDK / Dev.CD Jan 97 SDK2.toast / Development Kits (Disc 2) / OpenDoc Development Framework / ODFDev / ODF / Internet / SLCySink.xh < prev    next >
Encoding:
Text File  |  1996-09-16  |  3.7 KB  |  173 lines  |  [TEXT/MPS ]

  1.  
  2. /*
  3.  * This file was generated by the SOM Compiler.
  4.  * FileName: SLCySink.xh.
  5.  * Generated using:
  6.  *     SOM Precompiler somipc: 2.18
  7.  *     SOM Emitter emitxh.dll: 2.33
  8.  */
  9.  
  10. #ifndef SOM_Module_FW_defined
  11. #define SOM_Module_FW_defined 1
  12. #include <som.xh>
  13.  
  14. /*
  15.  * Start of user-defined types:
  16.  */
  17. class SOMClass;
  18. class SOMObject;
  19. class FW_OSink;
  20. class CyberStream;
  21.  
  22. /*
  23.  * End of user-defined types.
  24.  */
  25. #endif /* SOM_Module_FW_defined */
  26.  
  27. #ifndef SOM_FW_OCyberSink_xh
  28. #define SOM_FW_OCyberSink_xh
  29.  
  30. class FW_OCyberSink;
  31.  
  32. #define FW_OCyberSink_MajorVersion 1
  33. #define FW_OCyberSink_MinorVersion 0
  34.  
  35. /*
  36.  * Passthru lines: File: "C.xh", "before"
  37.  */
  38. class CyberStream;
  39. typedef CyberStream* FW_HCyberStream;
  40.  
  41. /* C++ SOM defs */
  42. #include <somcls.xh>
  43. #include <somcm.xh>
  44.  
  45. /* C++ parent defs */
  46. #ifndef SOM_FW_OSink_xh
  47. #include <SLASinks.xh>
  48. #endif
  49.  
  50. #ifndef FW_OCyberSink_API
  51. #define FW_OCyberSink_API
  52. /*
  53.  * -- The Class API
  54.  */
  55.  
  56. /*
  57.  * Start of user-defined types:
  58.  */
  59.  
  60. /*
  61.  * End of user-defined types.
  62.  */
  63.  
  64. #ifdef OLDIBMSOMAPISUPPORT
  65. #define FW_OCyberSinkCClassData FW_OCyberSinkClassData
  66. #define FW_OCyberSinkNewClass(major,minor) somNewVersionedClassReference(FW_OCyberSink,major,minor)
  67. #endif
  68.  
  69. /* define xxxMetaClass macro to facilitate (cls ## MetaClass) */
  70. #define FW_OCyberSinkMetaClass SOMClass
  71.  
  72. #if PRAGMA_ALIGN_SUPPORTED
  73. #  pragma options align=power
  74. #endif
  75.  
  76. /* The API to the FW_OCyberSink class object, and the methods it introduces. */
  77. SOMEXTERN struct FW_OCyberSinkClassDataStructure {
  78. #ifdef OLDIBMSOMAPISUPPORT
  79.     SOMClass            *classObject;    /* always zero, use somNewClassReference instead */
  80. #else
  81.     long zero;
  82. #endif
  83.     somStaticClassInfo *sci;
  84.     somDToken        instanceDataToken;
  85.     long reserved [3];
  86.     somMToken InitFromStream;
  87. } SOMDLINK FW_OCyberSinkClassData;
  88.  
  89. #if PRAGMA_ALIGN_SUPPORTED
  90. #  pragma options align=reset
  91. #endif
  92.  
  93. #if !defined(FW_OCyberSink_Class_Source) && !defined(SOM_Module_slcysink_Source)
  94. #if PRAGMA_IMPORT_SUPPORTED
  95. #pragma import list FW_OCyberSinkClassData
  96. #endif
  97. #endif
  98.  
  99.  
  100. /*
  101.  * -- Typedefs and inline method declarations for left path inherited methods
  102.  * -- are omitted because this compilation had -museinheritedmethods in effect
  103.  */
  104.  
  105.  
  106. /*
  107.  * -- Typedefs for FW_OCyberSink Method Procedures
  108.  */
  109. SOMEXTERN {
  110. typedef void   (* SOMLINK somTD_FW_OCyberSink_InitFromStream)(FW_OCyberSink *somSelf, Environment *ev,
  111.         CyberStream* cs);
  112. }
  113.  
  114. #endif /* FW_OCyberSink_API */
  115.  
  116.  
  117. /*
  118.  * -- This emitter treats Method Tokens as Thunks by default.
  119.  * -- Use the sc modifier "nothunks" to change this default
  120.  */
  121. #undef somresolve_
  122. #define somresolve_(obj,mToken) ((somMethodProc*)((void)obj, mToken))
  123.  
  124. /*
  125.  * -- The C++ Wrapper Class for FW_OCyberSink
  126.  */
  127. class FW_OCyberSink : public FW_OSink
  128. {
  129. public:
  130.  
  131. // FW_OCyberSink::new registers use of the class object, and then uses somNew
  132. // to allocate memory and load the object method table pointer. 
  133. void *operator new(size_t size)
  134. {
  135.     SOM_IgnoreWarning(size);
  136.     // Allocate memory using the default allocator for FW_OCyberSink, and
  137.     // clear mem & set method table pointer, call basic initialization
  138. #ifdef SOMCHKNULL
  139.     void * __somResult = (void *)
  140.       somNewObject(FW_OCyberSink);
  141.     SOMCHKNULL(__somResult);
  142.     return __somResult;
  143. #else
  144.     return (void*) somNewObject(FW_OCyberSink);
  145. #endif
  146. }
  147.  
  148. // FW_OCyberSink::delete uses the default deallocator for the object's class.
  149. void operator delete(void * obj)
  150. {
  151.     if (obj) {
  152.         SOM_Resolve(obj,SOMObject,somFree)
  153.            ( (SOMObject*) obj );
  154.     }
  155. }
  156.  
  157. /* method: InitFromStream */
  158. void   InitFromStream(Environment *ev,
  159.         CyberStream* cs)
  160. {
  161.    SOM_ResolveD(this,FW_OCyberSink,FW_OCyberSink,InitFromStream)
  162.     (this,ev,cs);
  163. #ifdef SOMCHKEXCEPT
  164.       SOMCHKEXCEPT;
  165. #endif
  166. }
  167.  
  168. };   /* FW_OCyberSink */
  169.  
  170.  
  171.  
  172. #endif       /* SOM_FW_OCyberSink_xh */
  173.